mir: properly handle empty clipboard
authorWilliam Hua <william.hua@canonical.com>
Mon, 9 Jan 2017 17:04:48 +0000 (12:04 -0500)
committerWilliam Hua <william.hua@canonical.com>
Mon, 9 Jan 2017 17:04:48 +0000 (12:04 -0500)
https://bugzilla.gnome.org/show_bug.cgi?id=775732

gdk/mir/gdkmirdisplay.c

index 12a76791514f8bdaf3ab6acc8dcc0eff9854ab46..8b210299d68930a0a8a00ef23d853223c297c1f7 100644 (file)
@@ -743,10 +743,16 @@ gdk_mir_display_real_convert_selection (GdkDisplay *display,
 
   paste_data = g_variant_get_fixed_array (mir_display->paste_data, &paste_size, sizeof (guchar));
   paste_header = (const gint *) paste_data;
-  paste_formats = g_ptr_array_new_full (paste_header[0], g_free);
 
-  for (i = 0; i < paste_header[0]; i++)
-    g_ptr_array_add (paste_formats, g_strndup (paste_data + paste_header[1 + 4 * i], paste_header[2 + 4 * i]));
+  if (paste_data)
+    {
+      paste_formats = g_ptr_array_new_full (paste_header[0], g_free);
+
+      for (i = 0; i < paste_header[0]; i++)
+        g_ptr_array_add (paste_formats, g_strndup (paste_data + paste_header[1 + 4 * i], paste_header[2 + 4 * i]));
+    }
+  else
+    paste_formats = g_ptr_array_new_with_free_func (g_free);
 
   if (target == gdk_atom_intern_static_string ("TARGETS"))
     {